Method and apparatus for generating menu information

ABSTRACT

Methods and Apparatus related to generating representations of information. The information may include menu information for merchants such as restaurants. Referring to menus, methods may include receiving potential information for a first menu, and receiving indications of associations of the information with the first menu and/or any number of additional menus. Information and/or associations may later be updated by a desired set of users.

CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 12/855,023 filed Aug. 12, 2010, which is a continuation-in-part of U.S. patent application Ser. No. 11/859,876 filed Sep. 24, 2007 (now U.S. Pat. No. 7,840,591 issued on Nov. 23, 2010), entitled “METHOD AND APPARATUS FOR ASSOCIATING MENU INFORMATION” and U.S. patent application Ser. No. 11/859,886 filed Sep. 24, 2007 (now U.S. Pat. No. 7,870,166 issued on Jan. 11, 2011) entitled “METHOD AND APPARATUS FOR MENU GENERATION,” which are hereby incorporated herein by reference.

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings are not intended to be drawn to scale. In the drawings, each identical or similar component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled or act identified in every drawing. In the drawings:

FIG. 1 shows a computer system architecture that may be used to perform one or more acts in accordance with some embodiments;

FIG. 2 shows an example set of database tables that may be maintained in some embodiments;

FIG. 3 shows an example process that may be performed by some embodiments;

FIG. 4 shows an example process that may be performed by some embodiments;

FIG. 5 shows an example process that may be performed by some embodiments; and

FIGS. 6-9 show example interfaces that may be used in some embodiments.

DETAILED DESCRIPTION Terms

The term “product” means any machine, manufacture and/or composition of matter, unless expressly specified otherwise.

The term “process” means any process, algorithm, method or the like, unless expressly specified otherwise.

Each process (whether called a method, algorithm or otherwise) inherently includes one or more steps, and therefore all references to a “step” or “steps” of a process have an inherent antecedent basis in the mere recitation of the term ‘process’ or a like term. Accordingly, any reference in a claim to a ‘step’ or ‘steps’ of a process has sufficient antecedent basis.

A reference to “another embodiment” in describing an embodiment does not imply that the referenced embodiment is mutually exclusive with another embodiment (e.g., an embodiment described before the referenced embodiment), unless expressly specified otherwise.

The terms “including”, “comprising”, “having”, “containing”, “involving”, and variations thereof mean “including but not limited to”, unless expressly specified otherwise. The terms “a”, “an” and “the” mean “one or more”, unless expressly specified otherwise. The term “plurality” means “two or more”, unless expressly specified otherwise. The term “herein” means “in the present application, including anything which may be incorporated by reference”, unless expressly specified otherwise.

The phrase “at least one of”, when such phrase modifies a plurality of things (such as an enumerated list of things) means any combination of one or more of those things, unless expressly specified otherwise. For example, the phrase “at least one of a widget, a car and a wheel” means either (i) a widget, (ii) a car, (iii) a wheel, (iv) a widget and a car, (v) a widget and a wheel, (vi) a car and a wheel, or (vii) a widget, a car and a wheel.

The phrase “based on” does not mean “based only on”, unless expressly specified otherwise. In other words, the phrase “based on” describes both “based only on” and “based at least on”. Similarly, the phrase “based on” does not mean “based on the entirety of”, “based on all of”, or variations thereon, unless expressly specified otherwise.

The term “e.g.” and like terms mean “for example”, and thus does not limit the term or phrase it explains. For example, in the sentence “the computer sends data (e.g., instructions, a data structure) over the Internet”, the term “e.g.” explains that “instructions” are an example of “data” that the computer may send over the Internet, and also explains that “a data structure” is an example of “data” that the computer may send over the Internet. However, both “instructions” and “a data structure” are merely examples of “data”, and other things besides “instructions” and “a data structure” can be “data”.

The term “determining” and grammatical variants thereof (e.g., to determine a price, determining a value, determine an object which meets a certain criterion) is used in an extremely broad sense. The term “determining” encompasses a wide variety of actions and therefore “determining” can include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” can include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” can include resolving, selecting, choosing, establishing, and the like.

The term “determining” does not imply certainty or absolute precision, and therefore “determining” can include estimating, predicting, guessing and the like. The term “determining” does not imply that mathematical processing must be performed, and does not imply that numerical methods must be used, and does not imply that an algorithm or process is used. The term “determining” does not imply that any particular device must be used. For example, a computer need not necessarily perform the determining.

The terms “an embodiment”, “embodiment”, “embodiments”, “the embodiment”, “the embodiments”, “one or more embodiments”, “some embodiments”, “certain embodiments”, “one embodiment”, “another embodiment” and the like mean “one or more (but not all) embodiments of the present invention”, unless expressly specified otherwise.

The term “electronic message” and variations thereof used herein should be understood to mean any electronic representation of information. For example an HTTP message, an XMLHTTP request, an SMS message, an MMS message, a database message (e.g., SQL message) or any other series of electrical signals that represent information may be considered an electronic message. An electronic message does not include information identifying a source and/or destination such as the information typically present in a TCP/IP packet header. Rather, the electronic message should be considered the body/content of such a packet.

The terms “representation” and “indication” of a thing and variations thereof used herein in reference to a thing should be understood to refer to any indication of at least a portion and/or characteristic of the thing. An indication of information, for example, may include any indication of at least a portion of the information. In some embodiments, the information may be determined by a person or computing device from the indication of the information. In some example implementations, an indication may include a copy of the information in any of a variety of formats, compressions, and/or encryptions. In another example implementation, an indication may include an index or other identifier, such as a position in a list, an ID number, or a database key. An indication of a thing may be in the same or different medium as an original thing. For example, a number “1” may indicate a sound, a color, a menu item, or any other thing depending, e.g., on the configuration of a computing system configured to interpret the number. In some implementations, an indication may be divided into a plurality of portions, such as a plurality of electronic messages being transmitted from one location to another. In some implementations, multiple indications may be combined into a single message.

Forms of Sentences

Where a limitation of a first claim would cover one of a feature as well as more than one of a feature (e.g., a limitation such as “at least one widget” covers one widget as well as more than one widget), and where in a second claim that depends on the first claim, the second claim uses a definite article “the” to refer to the limitation (e.g., “the widget”), this does not imply that the first claim covers only one of the feature, and this does not imply that the second claim covers only one of the feature (e.g., “the widget” can cover both one widget and more than one widget).

When an ordinal number (such as “first”, “second”, “third” and so on) is used as an adjective before a term, that ordinal number is used (unless expressly specified otherwise) merely to indicate a particular feature, such as to distinguish that particular feature from another feature that is described by the same term or by a similar term. For example, a “first widget” may be so named merely to distinguish it from, e.g., a “second widget”. Thus, the mere usage of the ordinal numbers “first” and “second” before the term “widget” does not indicate any other relationship between the two widgets, and likewise does not indicate any other characteristics of either or both widgets. For example, the mere usage of the ordinal numbers “first” and “second” before the term “widget” (1) does not indicate that either widget comes before or after any other in order or location; (2) does not indicate that either widget occurs or acts before or after any other in time; and (3) does not indicate that either widget ranks above or below any other, as in importance or quality. In addition, the mere usage of ordinal numbers does not define a numerical limit to the features identified with the ordinal numbers (e.g., “a plurality of first widgets” indicates two or more widgets that are distinct from other widgets). For example, the mere usage of the ordinal numbers “first” and “second” before the term “widget” does not indicate that there must be no more than two widgets.

When a single device or article is described herein, more than one device/article (whether or not they cooperate) may alternatively be used in place of the single device/article that is described. Accordingly, the functionality that is described as being possessed by a device may alternatively be possessed by more than one device/article (whether or not they cooperate).

Similarly, where more than one device or article is described herein (whether or not they cooperate), a single device/article may alternatively be used in place of the more than one device or article that is described. For example, a plurality of computer-based devices may be substituted with a single computer-based device. Accordingly, the various functionality that is described as being possessed by more than one device or article may alternatively be possessed by a single device/article.

The functionality and/or the features of a single device that is described may be alternatively embodied by one or more other devices which are described but are not explicitly described as having such functionality/features. Thus, other embodiments need not include the described device itself, but rather can include the one or more other devices which would, in those other embodiments, have such functionality/features.

Disclosed Examples and Terminology are not Limiting

Neither the Title (set forth at the beginning of the first page of the present application) nor the Abstract (set forth at the end of the present application) is to be taken as limiting in any way as the scope of the present invention. An Abstract has been included in this application merely because an Abstract of not more than 150 words is required under 37 C.F.R. §1.72(b).

The title of the present application and headings of sections provided in the present application are for convenience only, and are not to be taken as limiting the disclosure in any way.

Numerous embodiments are presented for illustrative purposes only. The described embodiments are not, and are not intended to be, limiting in any sense. One of ordinary skill in the art will recognize that the present invention may be practiced with various modifications and alterations, such as structural, logical, software, and electrical modifications. Although particular features of the present invention may be described with reference to one or more particular embodiments and/or drawings, it should be understood that such features are not limited to usage in the one or more particular embodiments or drawings with reference to which they are described, unless expressly specified otherwise.

Devices that are described as in communication with each other need not be in continuous communication with each other, unless expressly specified otherwise. On the contrary, such devices need only transmit to each other as necessary or desirable, and may actually refrain from exchanging data most of the time. For example, a machine in communication with another machine via the Internet may not transmit data to the other machine for long periods of time (e.g., weeks at a time). In addition, devices that are in communication with each other may communicate directly or indirectly through one or more intermediaries.

A description of an embodiment with several components or features does not imply that all or even any of such components/features are required. On the contrary, a variety of optional components are described to illustrate the wide variety of possible embodiments of the present invention. Unless otherwise specified explicitly, no component/feature is essential or required.

Although process acts, algorithms or the like may be described in a particular sequential order, such processes may be configured to work in different orders. In other words, any sequence or order of acts that may be explicitly described does not necessarily indicate a requirement that the acts be performed in that order. The acts of processes described herein may be performed in any order. Further, some acts may be performed simultaneously despite being described or implied as occurring non-simultaneously (e.g., because one act is described after the other act). Further more, acts which are described as separate may be performed as a single act in some embodiments. Moreover, the illustration of a process by its depiction in a drawing does not imply that the illustrated process is exclusive of other variations and modifications thereto, does not imply that the illustrated process or any of its acts are necessary to the present invention, and does not imply that the illustrated process is preferred.

Although a process may be described as including a plurality of acts, that does not imply that all or any of the acts are preferred, essential or required. Various other embodiments within the scope of the present invention may include other processes that omit some or all of the described acts. Unless otherwise specified explicitly, no act is essential or required.

Although a process or product may be described singly or without reference to other processes or products, in some embodiments the process or product may interact with other processes or products. For example, such interaction may include linking one business model to another business model. Such interaction may be provided to enhance the flexibility or desirability of the process.

An enumerated list of items (which may or may not be numbered) does not imply that any or all of the items are mutually exclusive, unless expressly specified otherwise. Likewise, an enumerated list of items (which may or may not be numbered) does not imply that any or all of the items are comprehensive of any category, unless expressly specified otherwise. For example, the enumerated list “a computer, a laptop, a PDA” does not imply that any or all of the three items of that list are mutually exclusive and does not imply that any or all of the three items of that list are comprehensive of any category. Also, an enumerated list of items (which may or may not be numbered) does not imply that any or all of the items are equivalent to each other or readily substituted for each other.

No embodiment of method steps or product elements described in the present application constitutes the invention claimed herein, or is essential to the invention claimed herein, or is coextensive with the invention claimed herein, except where it is either expressly stated to be so in this specification or expressly recited in a claim. The preambles of the claims that follow recite purposes, benefits and possible uses of the claimed invention only and do not limit the claimed invention.

Computing

It should be appreciated that the various processes described herein may be implemented by, e.g., appropriately programmed computer systems, e.g., general purpose computers 101 and/or computing devices 103, such as those illustrated in FIG. 1. A computing device 103 may include a specialized or general purpose computing device such as a cellular phone, a personal digital assistant, and/or any other portable or non-portable computing system that is not a general purpose computer.

A “processor” 105 means one or more microprocessors, central processing units (CPUs), computing devices, microcontrollers, digital signal processors, application specific integrated circuits, or like devices or any combination thereof. A processor may include an Intel®Pentium®, Centrino®, and/or Core® processor. Typically, a processor 105 will receive instructions (e.g., from a memory or like device), and execute those instructions, thereby performing one or more processes defined by those instructions.

Thus a description of a process is likewise a description of an apparatus for performing the process. The apparatus that performs the process may include, e.g., a processor 105 and those input devices and/or output devices (e.g., a keyboard 107, mouse, trackball, microphone, touch screen, printing device, display screen 109, speaker, network interface 111) that are appropriate to perform the process.

Further, programs (i.e., collections of instructions) that implement such methods (as well as other types of data) may be stored and transmitted using a variety of media (e.g., machine-readable media) in a number of manners. In some embodiments, hard-wired circuitry or custom hardware may be used in place of, or in combination with, some or all of the software instructions that can implement the processes of various embodiments. Thus, various combinations of hardware and software may be used instead of software only.

In some embodiments, processor 105 may execute an operating system which may include, for example, the Windows-based operating systems (e.g., Windows NT, Windows 2000 (Windows ME), Windows XP, Windows Vista) available from the Microsoft Corporation, MAC OS System X operating system available from Apple, one or more of the Linux-based operating system distributions (e.g., the Enterprise Linux operating system available from Red Hat, Inc.), the Solaris operating system available from Sun Microsystems, or UNIX operating systems available from various sources. Many other operating systems may be used, and the invention is not limited to any particular operating system.

The processor and operating system together may define a computer platform for which programs stored on a machine-readable medium may be written in various programming languages, including an object-oriented programming language, such as SmallTalk, Java, C++, Ada, Python, or C# (C-Sharp), functional programming languages, scripting programming languages such as JavaScript, and/or logical programming languages. Various aspects of the invention may be implemented in a non-programmed environment (e.g., documents created in HTML, XML or other format that, when viewed in a window of a browser program, render aspects of a GUI or perform other functions). Some implementations of the present invention may be implemented using a plurality of programming languages and techniques known collectively as AJAX to provide a user with an interactive web-based user interface.

Various embodiments of the present invention may include a network environment including one or more computing systems (e.g., general purpose computers 101, other computing devices 103) in communication through one or more communication networks (e.g., a LAN 119, the Internet 121). The computer systems may communicate directly or indirectly, via any wired or wireless medium (e.g., the Internet 121, LAN 119, WAN or Ethernet, Token Ring, a telephone line, a cable line, a radio channel, an optical communications line, commercial on-line service providers, bulletin board systems, a satellite communications link, cellular telephone networks, a WI-FI network, a Bluetooth communication link, a combination of any of the above).

Various aspects of the invention (e.g., program elements stored on machine-readable media and executable by one or more processors) may be distributed among one or more computer systems configured to provide a service to one or more client computer systems. For example, in some embodiments, a plurality of computing systems may be organized as a central authority connected to a LAN or other communication network. These computing systems may receive requests and other information from remote computing systems through the Internet 121.

In some embodiments of the present invention, one or more computer systems may act as one or more database servers. The database server may respond to database requests such as structured query language (SQL) queries by providing access to a database (e.g., searching of the database, writing to the database). The database server may maintain one or more database tables having information stored therein to facilitate the operation of some embodiments.

For example, FIG. 2 illustrates one exemplary set of database tables that may be used in some implementations of the present invention. It should be recognized that the invention is not limited to any particular set of database tables or even a single database table.

As illustrated in FIG. 2, in some implementations, one database table may include an item table 201. The item table 201 may include an entry for each item (e.g., each menu) maintained by a computer system performing a process in accordance with some embodiments of the present invention. The item table 201 may include database elements (i.e., columns) for each type of information that may be entered about an item. As illustrated, some types of information may include images, categories, descriptions, hours, delivery boundaries, and soft drink packages. Such information is discussed in more detail below and is not limited to these examples.

As illustrated in FIG. 2, in some implementations, one databases table may include an information table 203. The information table 203 may associate content of information with a label that may be used to refer to that content. For example, the information label IMG1 may is associated with the image file IMAGE1.JPG in the illustrated example of FIG. 2.

The combination of the item table 201 and the information table 203 may be used to determine a set of information associated with each item entry in the item table 201. For example, the description associated with MENU3 may be determined by referencing the description element to determine the content “The best” DSCR1 “in town.” The label DSCR1 may be determined by referencing the information table 203 to determine the value “Mexican food”. These may be combined to determine the content of the description of MENU3 as “The best Mexican food in town.”

In some embodiments, default values for content may also be determined in a similar manner. For example, if content of an entry is not filled with a value in the item table 201, the information table 203 may be searched for an appropriate default content value. As illustrated, the value of hours content for MENU1 may be determined to be “12-5;M-S” by performing such a search to find the default hours information

Although the content of the database tables are illustrated as simple text or image files, in other implementations, the content may include portions of HTML or other content. HTML may be arranged to generate a webpage or other interface layout incorporating the desired content, for example according to an interface template such as an XML document.

It should be recognized that while in this example illustration, database labels are used to reference from one entry into another in database tables, in other embodiments, any other method of referencing stored information may be used. For example, functions that determine which information to access may be used in some implementations, XML tags defining a general interface layout may be used in some implementation, and any other method desired may be used in some implementations

It should further be understood that in some embodiments information within a content entry may have further information references to other information entries. For example, in some implementations, an item entry may correspond to menu items available for sale. An information item may include a list of menu items. That list of menu items may reference individual other information content in the information table 203 that provide descriptions, images, prices, and/or any other information desired about some or all of the menu items. Such nesting of information may include any number of desired levels.

In some embodiments, a maintained database table may include an association table 205. The association table 205 may include information related to the associations between content in the item table 201 and content in the information table 203. For example, the association table's first entry indicates that the content of the description element of the MENU1 entry of the item table 201 is associated with the information item DSCR1 of the information table 203. Such an association table 205 may be useful in some implementation, though may not be needed in other implementations.

It should be recognized that content of information and associations between items and information may easily be changed by the example database tables or any other set of database tables. In some implementations, content of entries in the item table 201 may act as pointers to content in the information table 203 allowing a single piece of content in the information table to be referenced by multiple item entries. Such pointers allow a single piece of information to be edited for all items associated with that information, as discussed below. In some implementations, rather than multiple pointers to the same content, each time information is to be associated with a new item, a new copy of the information may be made in the information table, and each pointer from an item to information may point to a unique copy of the information. Such copying may allow information to be customized individually for each item as discussed below.

Aside from database servers, in some embodiments, one or more computer systems may act as a web server. A web server may be configured to respond to network requests (e.g., HTTP messages, XMLHTTP requests) from web browsers executed by remote computer systems. For example, a web browser 123 executed by a computing system may direct an HTTP message through the Internet 121 to an edge routing device 125 connected to the LAN 119. The edge routing device 125 may be configured to direct the HTTP message to the web server through the LAN 119. The web server may provide a response (e.g., an HTML document) to the web browser 123 through the edge routing device 125 and Internet 121. The web server may be configured to communicate with other computer systems (e.g., a database server) to generate responses to such a received request.

In some embodiments, a server computer/centralized authority may not be necessary or desirable. For example, the present invention may, in an embodiment, be practiced on one or more computing devices without a central authority. In such an embodiment, any functions described herein as performed by a server or data described as stored on a general purpose computer may instead be performed by or stored on one or more such computing devices.

The term “machine-readable medium” refers to any medium that participates in providing data (e.g., instructions, data structures) which may be read by a computer, a processor or a like device. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media include, for example, optical or magnetic disks 113 and other persistent memory. Volatile media include dynamic random access memory 115 (DRAM), which typically constitutes the main memory of a computer system. Transmission media include coaxial cables, copper wire and fiber optics, including the wires that comprise a system bus 117 coupled to the processor. Transmission media may include or convey acoustic waves, light waves and electromagnetic emissions, such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of machine-readable media include, for example, a floppy disk, a flexible disk, a hard disk, a magnetic tape, any other magnetic medium, a CD-ROM, a DVD, any other optical medium, punch cards, a paper tape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH-EEPROM, any other memory chip or cartridge, a carrier wave, or any other medium from which a computer system can read.

Various forms of machine-readable media may be involved in carrying data (e.g., sequences of instructions) to a processor. For example, data may be (i) delivered from RAM to a processor; (ii) carried over a wireless transmission medium; (iii) formatted and/or transmitted according to numerous formats, standards or protocols, such as Ethernet (or IEEE 802.3), SAP, ATP, Bluetooth™, and TCP/IP, TDMA, CDMA, and 3G; and/or (iv) encrypted to ensure privacy or prevent fraud in any of a variety of ways well known in the art.

Thus a description of a process is likewise a description of a machine-readable medium storing a program for performing the process. The machine-readable medium can store (in any appropriate format) those program elements that are appropriate to perform the process.

Where a process is described, in some embodiments the process may operate without any user intervention. In other embodiments, the process includes some human intervention (e.g., an act is performed by or with the assistance of a human).

Just as the description of various acts in a process does not indicate that all the described acts are required, embodiments of an apparatus may include one or more computer systems operable to perform some (but not necessarily all) of the described process.

Likewise, just as the description of various acts in a process does not indicate that all the described acts are required, embodiments of a machine-readable medium storing a program or data structure include a machine-readable medium storing a program that, when executed, can cause one or more processors to perform some (but not necessarily all) of the described process.

Where databases are described, it will be understood by one of ordinary skill in the art that (i) alternative database structures to those described may be readily employed, and (ii) other memory structures besides databases may be readily employed. Any descriptions of any sample databases presented herein are illustrative arrangements for stored representations of information. Any number of other arrangements may be employed besides those suggested herein. Further, any database format (including relational databases, object-based models and/or distributed databases) may be used to store and manipulate the data types described herein. Likewise, object methods or behaviors of a database may be used to implement processes described herein. In addition, the databases may, in a known manner, be stored locally or remotely from a device which accesses data in such a database.

Continuing Applications

The present disclosure provides, to one of ordinary skill in the art, an enabling description of several embodiments and/or inventions. Some of these embodiments and/or inventions may not be claimed in the present application, but may nevertheless be claimed in one or more continuing applications that claim the benefit of priority of the present application. Applicants intend to file additional applications to pursue patents for subject matter that has been disclosed and enabled but not claimed in the present application.

35 U.S.C. §112, Paragraph 6

In a claim, a limitation of the claim which includes the phrase “means for” or the phrase “step for” means that 35 U.S.C. §112, paragraph 6, applies to that limitation. In a claim, a limitation of the claim which does not include the phrase “means for” or the phrase “step for” means that 35 U.S.C. §112, paragraph 6 does not apply to that limitation, regardless of whether that limitation recites a function without recitation of structure, material or acts for performing that function. For example, in a claim, the mere use of the phrase “step of” the phrase “steps of” in referring to one or more steps of the claim or of another claim does not mean that 35 U.S.C. §112, paragraph 6, applies to that step(s). With respect to a means or a step for performing a specified function in accordance with 35 U.S.C. §112, paragraph 6, the corresponding structure, material or acts described in the specification, and equivalents thereof, may perform additional functions as well as the specified function.

Computers, processors, computing devices and like products are structures that can perform a wide variety of functions. Such products can be operable to perform a specified function by executing one or more programs, such as a program stored in a memory device of that product or in a memory device which that product accesses. Unless expressly specified otherwise, such a program need not be based on any particular algorithm, such as any particular algorithm that might be disclosed in the present application. It is well known to one of ordinary skill in the art that a specified function may be implemented via different algorithms, and any of a number of different algorithms would be a mere design choice for carrying out the specified function.

Therefore, with respect to a means or a step for performing a specified function in accordance with 35 U.S.C. §112, paragraph 6, structure corresponding to a specified function includes any product programmed to perform the specified function. Such structure includes programmed products which perform the function, regardless of whether such product is programmed with (i) a disclosed algorithm for performing the function, (ii) an algorithm that is similar to a disclosed algorithm, or (iii) a different algorithm for performing the function.

Where there is recited a means for performing a function hat is a method, one structure for performing this method includes a computing device (e.g., a general purpose computer) that is programmed and/or configured with appropriate hardware to perform that function.

Also includes a computing device (e.g., a general purpose computer) that is programmed and/or configured with appropriate hardware to perform that function via other algorithms as would be understood by one of ordinary skill in the art.

Disclaimer

Numerous references to a particular embodiment does not indicate a disclaimer or disavowal of additional, different embodiments, and similarly references to the description of embodiments which all include a particular feature does not indicate a disclaimer or disavowal of embodiments which do not include that particular feature. A clear disclaimer or disavowal in the present application shall be prefaced by the phrase “does not include” or by the phrase “cannot perform”.

INCORPORATION BY REFERENCE

Any patent, patent application or other document referred to herein is incorporated by reference into this patent application as part of the present disclosure, but only for purposes of written description in accordance with 35 U.S.C. §112, paragraph 1 and enablement in accordance with 35 U.S.C. §112, paragraph 1, and should in no way be used to limit, define, or otherwise construe any term of the present application where the present application, without such incorporation by reference, would not have failed to provide an ascertainable meaning, but rather would have allowed an ascertainable meaning for such term to be provided. Thus, the person of ordinary skill in the art need not have been in any way limited by any embodiments provided in the reference.

U.S. patent application Ser. No. 11/673,451 entitled Changing Trial Status in a Referral Service, U.S. patent application Ser. No. 11/859,065 entitled Products and Processes for Managing Revenue Sharing, U.S. patent application Ser. No. 11/859,876 entitled Method and Apparatus for Associating Menu Information, and U.S. patent application Ser. No. 12/757,316 entitled Multi-System Distributed Processing of Delivery Services are all hereby incorporated herein by reference.

EXEMPLARY EMBODIMENTS

Methods and apparatus related to generating representations' of information are disclosed herein. In particular, some embodiments relate to generating representations of menus. It is recognized, in one aspect of the present invention, that use of information from one source may be used for a plurality of purposes. For example, a single source may provide information regarding a first menu. The provided information may then be reused for a plurality of additional menus. It is also recognized that a plurality of sources may contribute to the generation of a single representation of information (e.g., by contributing small pieces of information). For example, sources may provide information and/or indicate associations between information and one or more menus. In some embodiments, the single source or other sources may indicate associates between the information and the plurality of additional menus. It is recognized that such systems and methods may be useful, for example, in distributing the work of generating menus of other information.

FIG. 3 illustrates an example process 300 according to one embodiment of the present invention that begins at block 301. Process 300 may be performed, for example, by one or more computer system.

As indicated at block 303, process 300 may include generating an entry for a first item. In some embodiments, the first item may include a listing of products and/or services available from a merchant. For example, in some implementations such a listing may include a menu for a particular restaurant, for example. In some embodiments, the entry may include a database entry, such as an entry into database table 201, described above. The entry may initially include default values for each element of the database table. Such default values may include default content and/or blank values. In some implementations, the entry may be generated in response to input from a source of information. The input may include, for example, a request to create the entry, an indication of an identifier for the entry, an indication of initial values for some or all of the elements of the entry, and/or any other desired information. In some implementations, such input may be received in the form of one or more electronic message.

In some implementations, the entry may be generated in response to a request received from a merchant or other person or entity associated with the entry. In some implementations, such a merchant may be asked to create a login to identify herself to a computer system implementing such a process, as is well known in the art. In other implementations, such a request may be received from another source. In still other implementations, the entry may be generated in response to some other identification of the existence of the merchant, such as input from a phone book or other catalogue of information.

As indicated at block 305, process 300 may include receiving an indication of a first piece of information. The first piece of information, in some implementation, may include information relevant to a listing of products and/or services available from a merchant. For example, in some implementations, the information may include a name of a merchant (e.g., a restaurant), a name of an available item (e.g., a food or drink item), a portion of or a full description of a merchant and/or item, an image, hours related to a merchants operation, delivery boundary information, and/or any information related to a merchant or item offered by a merchant (e.g., a product or service). In some implementations, the information may include sets of available products and/or services, for example, a particular set of standard Mexican food, a set of standard Italian food, a set of standard soft drinks (e.g., Coca-Cola products). In some implementations, the indication may be received as one or more electronic messages.

In some implementations, the indication of the first information may be received from a merchant or other person or entity associated with the information. In some implementations, before submitting information, the merchant may be asked to identify herself to a computer system by entering login information, as is known in the art.

In some implementations, the first information may be received from any other source. By allowing other sources to submit such information, responsibility for generating representations of information may be distributed to approved individuals and/or the public at large. Some implementations may ask such other sources to identify themselves through a login method, as is known in the art. In some implementations different abilities may be granted to a user based on whether a user decides to login to identify herself or to act anonymously without logging in. For example, in some implementations, new information may be added as trial information if entered anonymously and not given full entry status until approved by an administrator, the merchant, a user that logs in, or some other desired individual.

As indicated at block 307, some embodiments of process 300 may include receiving an indication of an association of the first information with the first item. An indication of an association may take any form, including a direct indication that the information and the item should be associated, an indication that the item and information should be associated to a same category, an indication that a default value should be used with the item and that the information should be used as a default value, a specific selection of the information for use with the item, and/or any other desired form from which an indication that the information and the item should be associated may be derived.

In some implementations, for example, when the information is received, the information may be associated with a category. For example, a category may include a type of a restaurant, a type of a merchant, etc. In some implementations, categories may be divided into any number of hierarchical subcategories and the information may be associated with a subcategory rather than a root main category. In some implementation association with subcategories may be carry inheritance characteristics so that association with a subcategory includes association with each higher level category.

The association with information and category may be performed in response to a separate request or as part of the receipt of the information. For example, a single electronic message may be submitted to indicate the information and a category. In other implementations separate messages from separate or the same source may indicate the information and the association. In some implementations, a user interface, such as a website, may allow users to enter information and/or associations and/or make selections of information and/or associations. In still other implementations categories and subcategories may not be used at all. In still other implementations categories and subcategories may be based on tags submitted by originators or later users of information and may alter as future tags are submitted (e.g., though a user interface).

In some implementations to facilitate matching of categorize of information with categories of items, items may be categorized into categories and/or subcategories that correspond to the categorizes and/or subcategories that the information may be associated with. By associating an item with a category and/or subcategory that information is associated with the item may thereby be associated with the information as well. In some implementations, an association of an item with a category and/or subcategory may be made in response to a request from the merchant, an administrator, member of the public, and/or any other desired individual. In some implementations, the information itself may include a request to make the association of the item with a category. Categories may be selected through a user interface, in some implementations. In some implementations such a request may include an indication of one or more tags to be associated with the item. In some implementations, categories with which information or items are associated with may change as tags or other indications indicate such changes.

In other embodiments, in addition to or instead of categories and subcategories, an indication of an association may take the form of a selection of particular information. Such selection may be facilitated through one or more user interfaces. For example, in one implementation, a website may provide a menu from which the information may be selected from among a plurality of possible information choices (e.g., the information in an information database table, as described above). A user of the interface may select (e.g. by clicking on the information with a mouse) the information and an electronic message identifying that selection may be transmitted to a computer system to indicate the selection of the association.

In still other embodiments, information may be associated with a default value. For example, a default value of a type of information entry for all items and/or a default value of content for items. In some such embodiments, the default values may be used in situation in which no other association or entry of information for a particular information item has been made. In some implementations, a receipt of an indication of an association may include not receiving information associating the item and any other information.

It should be understood that the above described implementations are provided as examples only and that indications of an association may take any form. It should further be understood that any combination of the above implementations and/or any other desired implementation may be performed in embodiments of the present invention. For example, a default value of a particular content for an item in a particular category may be used unless some other value from a selection of possible selection in that category is chosen by a user and submitted to a computer system implementing some embodiments of the present invention

As indicated at block 309, some embodiments of process 300 may include associating the first information with the first item. Such association may occur, for example, through one or more database tables. Associating items trough database tables is well known in the art.

As indicated at block 311, some embodiments of process 300 may include generating at least one representation of the first item using the first information. In some implementations, the representation may include a user interface, such as a website and/or a mobile device interface. Such a user interface may include a listing products and or services available from a merchant, such as a menu of food items available from a restaurant. In some implementations, such a representation may include an interactive interface through which a user may select items for delivery. Such interactive delivery interfaces are known in the art.

In some implementations, the at least one representation may be generated in accordance with one or more user interface templates. For example, a template may indicate a layout of content information and the content information may be entered into the layout to produce the representation. In some implementations, such an interface template may take the form of one or more XML documents.

As indicated at block 313, some embodiments of process 300 may include transmitting the at least one representation of the first item. The representation may be transmitted for example over a communication network such as the internet. In some implementations the transmission may be received by a user of a computer system and displayed through the computer system (e.g., through a web browser or mobile device display).

Process 300 may end as indicated at block 315. As indicated by dashed lines in FIG. 3, some embodiments, may include receiving further indications of information and associations and making associations with the information. In some implementations, new association may replace old associations, while in other applications associations may cumulate. In some implementations, an indication of an association may indicate whether an association should cumulate or replace a prior association. Later generated and/or transmitted representations may incorporate later changed associations and/or information.

FIG. 4 illustrates a process 400 that may be used to change associations and/or information in accordance with some embodiments of the present invention. Process 400 may be performed, for example, by a computer system and may begin at block 401.

As indicated at block 403, process 400 may include receiving an indication of a change to the first information. The indication of the change may include an edit to the information. For example such an edit may include an electronic message indicating that a portion of a textual description should be modified (e.g., to improve the description). By allowing such changes, some embodiments allow a plurality of users to collaborate to generate information and edits to the information so that the information is accurate in the opinions of a large number of people as those opinions and underlying acts change.

In some implementations, before an individual may edit information a user may be asked to login to a computer system, as is known in the art. In some implementations, if a user does not login, edits to information submitted by the user may be flagged or otherwise treated as trial information and may not be fully entered unless approved by some other user, as discussed above.

In some implementations, as indicated at block 405, process 400 may include changing the first information. Such change may include incorporating the indicated changes of block 403. For example, a stored description in a database table may be edited to reflect a change to the description that makes the description more accurate.

In some implementations an edit to information may affect a plurality of items. For example, as described above, this may occur if pointers from a plurality of items point to a single piece of information that is subsequently edited. In other implementations, each item may point to a unique copy of information so that an edit to information may only affect the single item, as described above.

In some embodiments, as indicated at block 407, process 400 may include receiving an indication of second information. Receiving such second information may be substantially similar to receiving the first information, as described above. A plurality of pieces of information may be received in such fashion. For example, a plurality of pieces of information may include a plurality of different descriptions, images, or other information as described above with respect to the first information. The information may be stored in one or more database tables, as described above. Such plurality of pieces of information may make up a selection of possible information displayed to a user to allow selection of information for association with an item through a user interface. Such a selection of information may be displayed to a user (e.g., through a website) when a user creates an initial entry and/or edits information and/or associations related to an existing entry.

In some embodiments, as indicated at block 409, process 400 may include receiving an indication of a change from an association with the first information to an association with the second information. Such an indication may be substantially similar to an indication of the first association. In response to receiving that indication, a computer system may disassociate the item from the first information and associate the item with the second information (e.g., through a database table) as indicated at block 411. and process 400 may end at block 413

Specific Example in the Delivery Domain

Some embodiments may include a website for providing information about restaurants, including menu information to potential customers of those restaurants. In some implementations, the website may provide delivery opportunities for some or all of the restaurants. The website may allow users to edit information and associations of information with menus.

In such embodiments, information identifying a restaurant's existence may be received by a computer system (e.g., from a customer of the restaurant, the owner of the restaurant, anyone else), and a data base entry may be made accordingly. Such information may be submitted through a web-based user interface, as is well known in the art. The web-based interface may allow selection of information that has previously been submitted (e.g., information stored in an information database table).

Further information may be received about the restaurant, another restaurant, or restaurants in general. For example, such information may include descriptions, images, generic food packages (e.g., a set of Mexican food, a set of soft drinks offered, etc.) and/or any other desired information. The information may be received from the restaurant, a customer of the restaurant, and/or any other desired individual. The information may be submitted through a web-based user interface, as is well known in the art.

In some implementations, an indication of an association of the information with the restaurant may be received. Such an association may indicate, for example, that a particular restaurant should be associated with a certain set of hours, a certain set of Mexican food, a set of delivery boundary streets, etc. Such an association may then be made through one or more database tables. The indication of the association may be submitted through a web-site interface, such as one that allows a user to select information to be associated out of a list of possible information.

Future users of the website may edit the information and associations to update or otherwise change the information associated with a particular restaurant. Such users may, for example use a web-based user interface to submit edits to information and/or new associations.

Users may also request representations of the menu of the restaurant through a web-based interface. The menu may be presented incorporating all the associated up to date information submitted by various users. It should be recognized that although this specific example describes an embodiment in the delivery restaurant domain, the present invention is not so limited. Rather embodiments of the invention include any items, information, and associations.

Template Examples

Some embodiments may include one or more templates. Such templates may be used to generate a menu for a merchant. Such templates may ease the creation of a menu for a merchant. Such templates may be used by one or more merchants, and/or one or more users to create a menu for the one or more merchants. Such templates may include material created by another, such as item information, option information, structure information, and so on. FIG. 5 illustrates an example method that may be used in some embodiments.

Some embodiments may include receiving an indication of one or more items for inclusion in a template as indicated at 501. Such an indication may include, for example, a description, a name, a picture, a price, a weight, a delivery price, a fragility, a dimension, and so on. Any number of such indications for any number of respective such items may be received as desired. One example may include an indication of a small pizza. Such an example indication may include a name of the item (e.g., small pizza), a price of the item (e.g., $9.00), a picture of the item (e.g., a picture of a pizza), a description of the item (e.g., a 10 inch diameter pizza), and/or any desired elements. Such an indication may include an indication of a set of items (e.g., Coke products) rather than an individual item. Such an indication may be received from an operator of a system, a user of a system, a merchant, and so on. Such items may be used for a plurality of menus associated with a plurality of merchants. Each item may include an alterable characteristic, such as price, and name of the item.

Some embodiments may include receiving an indication of options for the item(s) as indicated at 503. Such options may include, for example, elements other than an essence of an item, elements that may be changed with regard to an item, elements that may be added to an item, and so on. In one example, options may include toppings that may be added to a small pizza, a style of a small pizza, and/or a crust style of a small pizza. As another example, one set of items may include beverages, and options may include which beverage manufacturers (e.g., Coke or Pepsi). Such an indication may be received from an operator of a system, a user of a system, a merchant, and so on. Various sets of such options may be used in a plurality of menus associated with a plurality of merchants.

Some embodiments may include receiving an indication of a structure for a template and/or menu as indicated at block 505. Such a structure may define a position of items with respect to other items, an association of items and options, and so on. For example, a structure may define that for a pizza merchant, small pizza should be positioned above medium pizza and large pizza at a top of a menu, and that small pizza should have options for a set of toppings. Such an indication may be received from an operator of a system, a user of a system, a merchant, and so on. A structure may define a position in a menu for one or more items and/or one or more options with respect to other items and/or options. A structure may define how options and/or items are displayed in a menu based on the template.

Some embodiments may include determining a template 507. The template may be based on the items, options, and structure received. For example, a template to be used for pizza merchants may be determined based on a plurality of received items, options, and a structure that defines how they should be put together. The template may be determined in response to a user, and/or operator submitting a structure. The template may be associated with a type, category, size, and so on of merchants. Users may use the template to create menus for new merchants by selecting items, and/or options from the template.

Some embodiments may include receiving a request for a template from a user as indicated at 509. Such a request may include a request to generate a new merchant entry for a delivery website such as delivery.com. Such a request may be received from the merchant, from another user, and so on. Such a request may identify information about the merchant such as the type of merchant, the location of the merchant, and so on. Such information may be used to choose the template to be used (e.g., pizza menu for a pizza parlor). Such a request may include a choice of the template from among a set of possible templates (e.g., a list of all templates). Such a request may be from a web browser accessing a delivery and/or referral website. FIG. 6 illustrates an example interface that may be used to select a template.

Some embodiments may include transmitting an indication of the template to the user as indicated at 511. Such a transmission may be made in response to receiving the request. Such a transmission may be made to a web browser of a user from whom the request was received. Such a transmission may include a single transmission and/or transmissions in part as desired (e.g., items separately from options, items in groups, pictures separate from text, and so on). The template may be displayed to the user through the web browser. Providing the template may include providing an interface through which a user may select one or more items for inclusion in a menu. Providing the template may include providing an interface through which a user may select one or more option for an item included in a menu. FIGS. 7 and 8 illustrate example interfaces that may be provided. FIG. 7 illustrates an interface through which a user may select one or more items for inclusion in a menu. As illustrated in FIG. 7, a user may operate a check box to select an item and may enter a price for the item in a text box. FIG. 8 illustrates an interface through which a user may select one or more options for an item for inclusion in a menu. As illustrated in FIG. 8, a user may select a check box for inclusion of an option for an item.

Some embodiments may include receiving a selection of one or more items from the template to include in a menu as indicated at 513. Such a selection may be made through an interface. For example, a user that is establishing a menu for a pizza parlor may select the inclusion of a small pizza item in the menu. The selection may be performed, for example, by operating a control such as a check box, a button, and so on. FIG. 7 illustrates an example interface through which a user may make a selection of one or more items for inclusion in a menu. The user may place a check in each checkbox next to each item that the user wants to include in the menu. The user may enter a price for each item in a text box associated with the item in the template. Some embodiments may include a default price that may be changed by the user. In some embodiments, items selected may be included in a menu and unselected items may not be included in the menu. In some embodiments, a user may also change a name of an item from a default value to a desired value through such an interface and/or another interface (e.g., change a name from “small pizza” to “our famous pizza”).

Some embodiments may include receiving a selection of one or more options for one or more items to include in a menu as indicated at 515. Such a selection may be made through an interface. For example, a user that is establishing a menu for a pizza parlor that includes a small pizza may select the inclusion of a pepperoni and a sausage options for toppings of the pizza. The selection may be performed, for example, by operating a control such as a check box, a button, and so on. As another example, for a cheese pizza, options may include small, medium, and large. FIG. 8 illustrates an example interface through which a user may select options for inclusion in a menu. A user may select an option by clicking a checkbox next to each option that the user wishes to include in the menu.

Some embodiments may include different types of options. For example, some embodiments may include a typing option and some embodiments may include an addon option. A typing option may include, for example, a size, a type of crust, an option that defines the item and that without at least one of a set of possible options being true, the item is undefined. Some example options may include a size option, a topping option, a crust option, a flavor option, and a filling option. An addon option may include, for example, a topping, an additional thing to add to the item, an option that may adds something to the item, but that without the item is still defined. In some embodiments, if only one typing option for an item is selected, that item, when ordered through the menu may always have that type (e.g., a user may not be given the option to choose a type). In some embodiments, if only one addon option is selected for an item, a user may be given the option to select or unselect that option.

Some embodiments may include determining a menu based on the structure, the selection of item(s), and the selection of option(s) as indicated at 517. The menu may include each of the selected items so that a user may access the menu to order one or more of the items. The menu may include each of the selected options for each item so that for each selected item, the user may select one or more of the options for that item. Some items may have many options, some items may have no options, some items may have one option. In some embodiments, if there is only one option for an item selected (e.g., only a large size pizza is available for a pizza item) then the menu may not include a selection of options for that item but rather the only option available may always be selected.

Some embodiments may include allowing a user to include non-template items in the menu. For example, a user may add an item that is not on the template. Some embodiments may include allowing a user to make changes to an item and/or option in a template that affect the item only in the user's menu. For example, the user may change an image, a name, a position of, and so on of an item for the user's own menu. Some embodiments may include allowing a user such as an administrator to make a change to an item and/or option related to a template that may change all menus made using the template, that may change only future menus made using the template, and so on.

Some embodiments may include receiving a request for a menu of the merchant as indicated at 519. Such a request is described elsewhere. Such a request may include a request for a website. For example, a user may navigate to the delivery.com website and select a merchant from a listing of merchants from the website. The selection of the merchant may be a request for a menu of the merchant. The merchant may be the merchant for which the menu was created using the template as described above.

Some embodiments may include providing the menu as indicated at 521. The menu may include the menu determined based on the template, the selection of items, and the selection of options. Such providing may include providing a website through which a user may make a selection of items to be purchased from the merchant. The items may include one or more options. FIG. 9 illustrates one example interface that may be provided to a user to allow the selection of one or more items with one or more options. Upon selecting an item, the user may be prompted to select one or more options for the item. The user may select any number of items each having any number of options as desired.

Some embodiments may include receiving a request to purchase one or more items having one or more options as indicated at 523. Such a request may include an operation of a complete order control through the interface of the menu. Such a request may include a payment, an indication of an address for delivery, a request for delivery, and so on. Such a request may include a request for a particular merchant associated with the menu.

Some embodiments may include facilitating delivery of the one or more items from the merchant to the user as indicated at 525. Facilitating delivery may include delivering, transmitting information about delivery, transmitting information to a delivery agent, transmitting information to a merchant, and so on.

Some embodiments may include offering a user the option of creating a menu for the user or allowing the user to create his or her own menu. In some embodiments, if the user selects to create his or her own menu, the user may use the template system described above to generate a menu. In some embodiments, if the user selects to have a menu created for the user, the system and/or a representative of the system may perform any actions to create the menu, such as obtaining a menu and entering information into the system to generate the menu. In some embodiments, a system may offer a rebate to the user for selecting the option to create the menu for himself or herself, such as through the template system. For example, such a rebate may include a lower charge for providing a referral, of an order, a lower cost for providing a delivery service, a flat fee, an increase referral fee to a user that referred the merchant to the system, and so on.

It should be recognized that although some embodiments are described with respect to food items, that other embodiments may include any items of any type in any combination.

It should be recognized that although some embodiments are described with respect to items that have associated options, that some embodiments may include any combination of items and/or options in any order and any number of levels. For example, some items may have associated items, which themselves have associated option. Some embodiments may have items that have associated option which themselves have associated items.

It should be recognized that the given examples are non-limiting and that any action, element, and so on may or may not be part of some embodiments. For example, an ordering of action may be change, some actions may be taken in alternative form, some actions may not be taken, additional actions may be taken, different systems may be used, and so on.

MORE EMBODIMENTS

The following should be interpreted as embodiments, not as claims.

A. An apparatus comprising: a tangible machine readable medium having stored thereon a plurality of instructions that cause a computing device of a delivery service to perform a method comprising: receiving an indication of a plurality of items from a first user of the delivery service; receiving respective pieces of information, in which each respective piece of information is associated with a respective item of the plurality of items; determining a set of the plurality of items that may be added to a menu for a first merchant from whom customers of the delivery service may order items for delivery; determining a respective plurality of pieces of the information that may be associated with each item; allowing a user to include one or more of the plurality of items in a menu for the first merchant; allowing the user to include one or more respective pieces of information from each of the respective plurality of pieces of information to include in the menu. determining the menu based on the included items and the included information; receiving a request for the menu; providing the menu in response to receiving the request for the menu; receiving a request to purchase one or more of the items; and in response to receiving the request to purchase, facilitating delivery of the one or more items from the merchant.

A.1. The apparatus of claim A, in which each respective piece of information includes an option for a respective item. A.1.1. The apparatus of claim A.1, in which each option includes an addon option. A.1.2. The apparatus of claim A.1, in which each option includes a typing option. A.1.3. The apparatus of claim A.1, in which each option includes at least one of a size option, a topping option, a crust option, a flavor option, and a filling option. A.2. The apparatus of claim A, in which allowing the user to include one or more of the plurality of items includes providing an interface for a menu template. A.3. The apparatus of claim A, in which allowing the user to include one or more respective pieces of information of each respective plurality of pieces of information includes providing an interface for a menu template. A.4. The apparatus of claim A, in which allowing the user to include one or more respective pieces of information of each respective plurality of pieces of information and allowing the user to include one or more of the plurality of items includes providing an interface for a menu template in which a user may select items from the set of items and options for those selected items from the information. A.4.1. The apparatus of claim A.4, further comprising receiving a structure for the template. A.4.1.1. The apparatus of claim A.4.1, in which the structure defines a position for each item and each option in the template. A.4.1.2. The apparatus of claim A.4.1, in which the structure defines a position for each selected item and each selected option in the menu. A.5. The apparatus of claim A, further comprising receiving a structure for the menu, and in which determining the menu includes determining the menu based on the structure. A.6. The apparatus of claim A, further comprising the computing device, in which the computing device includes a processor. 

1-13. (canceled)
 14. An apparatus comprising: a computing device; and a non-transitory machine readable medium having stored thereon a plurality of instructions that when executed by the computing device cause the apparatus to: present a plurality of items that may be selected for inclusion in a menu of deliverable goods for a first merchant; receive a first selection of a subset of the plurality of items from a first user; present a plurality of pieces of information that may be selected to include in the menu as a modifier to an item in the subset of the plurality of items; receive a second selection of a subset of the plurality of pieces of information from a second user; present an interface through which an edit may be made to at least one of a piece of information of the subset of the plurality of pieces of information and the item in the subset of the plurality of items; receive the edit to at least one of the piece of information from a third user; receive a request for the menu of deliverable goods; in response to receiving the request, present the menu of deliverable goods based on the item, the piece of information and the edit.
 15. The apparatus of claim 14, in which each respective piece of information includes an option that may be applied to the item.
 16. The apparatus of claim 15, in which each option includes an addon option.
 17. The apparatus of claim 15, in which each option includes a typing option.
 18. The apparatus of claim 15, in which each option includes at least one of a size option, a topping option, a crust option, a flavor option, and a filling option.
 19. The apparatus of claim 14, in which presenting the plurality of items includes providing an interface for a menu template.
 20. The apparatus of claim 19, in which the instructions cause the apparatus to: receive a change to the menu temple and adjust the menu and at least one other menu that may be ordered from at least one other merchant in response receiving the change.
 21. The apparatus of claim 14, in which presenting the plurality of pieces of information includes providing an interface for a menu template.
 22. The apparatus of claim 21, in which the instructions cause the apparatus to: allow the second user to add at least one additional item not from the plurality of items to the menu through the interface by adding an item that is not in the menu template to the menu.
 23. The apparatus of claim 14, in which the plurality of instructions cause the apparatus to receive a structure for a menu template that defines which pieces of information may be added to which items.
 24. The apparatus of claim 23, in which the structure defines a position for each item and each piece of information in the menu.
 25. The apparatus of claim 24, in which the structure defines a position for each selected item and each selected piece of information in the menu.
 26. The apparatus of claim 14, in which the plurality of instructions cause the apparatus to receive a structure for the menu, determine the menu based on the structure, the selected subset of the plurality of items, the selected subset of the plurality of pieces of information, and the edit.
 27. The apparatus of claim 14, in which the computing device includes a processor.
 28. The apparatus of claim 14, in which the plurality of instructions cause the apparatus to associate the menu and a second menu of a second merchant with the edit in response to receiving the edit.
 29. The apparatus of claim 14, in which the plurality of instructions cause the apparatus to determine the menu to include the edit by the third user after the edit is received and determine the menu without the edit by the third user before the edit is received.
 30. The apparatus of claim 14, in which the plurality of instructions cause the apparatus to at least one of associate the edit with at least one other menu and associate the edit with only the menu.
 31. The apparatus of claim 14, in which the instructions cause the apparatus to: allow a fourth user to include one or more of the plurality of items and one or more pieces of information of the plurality of pieces of information in a second menu of items that may be delivered from a second merchant.
 32. The apparatus of claim 14, in which the first user and second user are different users.
 33. The apparatus of claim 14, in which the instructions cause the apparatus to: allow the second user to add at least one additional item not from the plurality of items to the menu.
 34. The apparatus of claim 14, in which the third user is different from the first and second users.
 35. A method comprising: presenting, by a computing device, a plurality of items that may be selected for inclusion in a menu of deliverable goods; receiving, by the computing device, a first selection of a subset of the plurality of items from a first user; presenting, by the computing device, a plurality of pieces of information that may be selected to include in the menu as a modifier to an item in the subset of the plurality of items; receiving, by the computing device, a second selection of a subset of the plurality of pieces of information from a second user; presenting, by the computing device, an interface through which an edit may be made to at least one of a piece of information of the subset of the plurality of pieces of information and the item in the subset of the plurality of items; receiving, by the computing device, the edit to at least one of the piece of information from a third user; receiving, by the computing device, a request for the menu of deliverable goods; in response to receiving the request, presenting, by the computing device, the menu of deliverable goods based on the item, the piece of information and the edit. 